<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>单对象查询分析</title>
    <script type="text/javascript" include="jquery,bootstrap,loader" src="../js/include-web.js"></script>
    <style>
        .control {
            position: absolute;
            top: 10px;
            right: 10px;
        }

        #map {
            position: absolute;
        }
    </style>
</head>
<body style=" margin: 0;overflow: hidden;background: #fff;width: 100%;height:100%;position: absolute;top: 0;">
<div id="map" style="width: 100%;height:100%"></div>
<div id="control" class="control" style='width:350px'>
    <div class="panel panel-default">
        <div class='panel-heading'>
            <h3 class='panel-title'>单对象查询分析</h3>
        </div>
        <div class='panel-body'>
            <div class='input-group'>
                <span class='input-group-addon'>源数据集<span title="必填字段" style="color: red;"> * </span>　</span>
                <input id='datasetName' type='text' class='form-control'
                       value='samples_processing_newyorkZone_R'/></div>
            <p></p>
            <div class='input-group'>
                <span class='input-group-addon'>查询对象数据集<span title="必填字段" style="color: red;"> * </span></span>
                <input id='datasetQuery' type='text' class='form-control'
                       value='samples_processing_singleRegion_R'/>
            </div>
            <p></p>
            <div class='input-group'>
                <span class='input-group-addon'>空间查询模式<span title="必填字段" style="color: red;"> * </span></span>
                <select class='form-control' id='mode' name='mode'>
                    <option value='CONTAIN'>包含</option>
                    <option value='CROSS'>交叉</option>
                    <option value='DISJOINT'>分离</option>
                    <option value='IDENTITY'>重合</option>
                    <option value='INTERSECT' selected>相交</option>
                    <option value='OVERLAP'>叠加</option>
                    <option value='TOUCH'>邻接</option>
                    <option value='WITHIN'>被包含</option>
                </select>
            </div>
            <p></p>
            <div align='right'>
                <input type='button' id='btn' class='btn btn-primary' value='创建'/>
            </div>
        </div>
    </div>
</div>
<script type="text/javascript" src="../../dist/include-classic.js"></script>
<script type="text/javascript">
    var host = window.isLocal ? document.location.protocol + "//" + document.location.host : "http://117.122.248.69:8090";
    var resultLayer,
        processingsUrl = host + "/iserver/services/distributedanalyst/rest/v1/jobs",
        mapURL = host + "/iserver/services/map-world/rest/maps/World",
        token = 'yurnlSeWak-vh77nAh73yrW_cHDTDJrfZxCVl7-h3GhMSMSNTPjvH7ykQviXfH1tOQ2ckJtUt6J9RY32GFNa6Q..',
        map = new SuperMap.Map("map", {
            controls: [
                new SuperMap.Control.Navigation(),
                new SuperMap.Control.Zoom(),
                new SuperMap.Control.LayerSwitcher()

            ], allOverlays: true
        });
    var layer = new SuperMap.Layer.TiledDynamicRESTLayer("World", mapURL, null, {maxResolution: "auto"});
    layer.events.on({"layerInitialized": addLayer});

    function addLayer() {
        map.addLayers([layer]);
        map.setCenter(new SuperMap.LonLat(-73.95, 40.75), 12);
    }

    var processingService = new SuperMap.REST.ProcessingService(processingsUrl);
    if (!window.isLocal) {
        SuperMap.SecurityManager.registerToken('http://117.122.248.69:8090/iserver', token);
    }

    bindClick();

    function bindClick() {
        $('#btn').on('click', function () {
            if ($('#msg_container')[0]) {
                $('#msg_container').remove();
            }
            showLoader();
            if (map && resultLayer) {
                map.removeLayer(resultLayer);
            }
            queryJobs();
        });
    }

    function queryJobs() {
        var singleObjectQueryJobsParameter = new SuperMap.SingleObjectQueryJobsParameter({
            datasetName: $('#datasetName').val(),
            datasetQuery: $('#datasetQuery').val(),
            mode: $('#mode option:selected').attr('value')
        });
        processingService.addQueryJob(singleObjectQueryJobsParameter, function (serviceResult) {
            if (serviceResult.error) {
                removeLoader();
                var errorMsg = serviceResult.error.errorMsg || "code: " + serviceResult.error.code;
                showAlert("创建失败!<br>" + errorMsg, false);
                return;
            }
            serviceResult.result.setting.serviceInfo.targetServiceInfos.map(function (info) {
                if (info.serviceType === 'RESTMAP') {
                    SuperMap.FetchRequest.get(info.serviceAddress + '/maps').then(function (response) {
                        return response.json();
                    }).then(function (result) {
                        var mapUrl = result[0].path;
                        resultLayer = new SuperMap.Layer.TiledDynamicRESTLayer("resultLayer", mapUrl, {transparent: true});
                        resultLayer.events.on({"layerInitialized": addLayer});

                        function addLayer() {
                            map.addLayer(resultLayer);
                            removeLoader();
                        }
                    });
                }
            });
        });
    }

    function showAlert(msg, state) {
        var className = "alert-";
        className += state ? "success" : "danger";
        if (!$('#msg_container')[0]) {
            var alertDiv = $("<div class='alert alert-dismissible' id='msg_container' role='alert' " +
                "style='z-index:800;position: absolute;top: 20px;left: 40%;width:400px;display: none'>" +
                "<button type='button' class='close' data-dismiss='alert' aria-label='Close'><span aria-hidden='true'>&times;</span></button>" +
                "<strong><p id='msg' style='word-wrap: break-word'></p></strong></div>");
            $('body').append(alertDiv)
        }
        $('#msg_container').addClass(className);
        $('#msg_container').slideDown(300);
        $('#msg').html(msg);
    }

</script>
</body>
</html>